#include "gtkcssrgbavalueprivate.h"
+#include "gtkcssstylepropertyprivate.h"
#include "gtkstylecontextprivate.h"
#include "gtksymboliccolorprivate.h"
gboolean for_color_property)
{
GtkSymbolicColor *symbolic;
- GtkCssValue *resolved;
+ GtkCssValue *resolved, *current;
g_return_val_if_fail (rgba != NULL, NULL);
- symbolic = _gtk_css_value_get_symbolic_color (rgba);
-
- if (symbolic == _gtk_symbolic_color_get_current_color ())
+ /* The computed value of the ‘currentColor’ keyword is the computed
+ * value of the ‘color’ property. If the ‘currentColor’ keyword is
+ * set on the ‘color’ property itself, it is treated as ‘color: inherit’.
+ */
+ if (for_color_property)
{
- /* The computed value of the ‘currentColor’ keyword is the computed
- * value of the ‘color’ property. If the ‘currentColor’ keyword is
- * set on the ‘color’ property itself, it is treated as ‘color: inherit’.
- */
- if (for_color_property)
- {
- GtkStyleContext *parent = gtk_style_context_get_parent (context);
-
- if (parent)
- return _gtk_css_value_ref (_gtk_style_context_peek_property (parent, GTK_CSS_PROPERTY_COLOR));
- else
- return _gtk_css_rgba_value_compute_from_symbolic (fallback, NULL, context, TRUE);
- }
+ GtkStyleContext *parent = gtk_style_context_get_parent (context);
+
+ if (parent)
+ current = _gtk_style_context_peek_property (parent, GTK_CSS_PROPERTY_COLOR);
else
- {
- return _gtk_css_value_ref (_gtk_style_context_peek_property (context, GTK_CSS_PROPERTY_COLOR));
- }
+ current = _gtk_css_style_property_get_initial_value (_gtk_css_style_property_lookup_by_id (GTK_CSS_PROPERTY_COLOR));
+ }
+ else
+ {
+ current = _gtk_style_context_peek_property (context, GTK_CSS_PROPERTY_COLOR);
}
- resolved = _gtk_style_context_resolve_color_value (context, symbolic);
+ resolved = _gtk_style_context_resolve_color_value (context, current, symbolic);
if (resolved == NULL)
return _gtk_css_rgba_value_compute_from_symbolic (fallback, NULL, context, for_color_property);
GtkCssValue *
_gtk_style_context_resolve_color_value (GtkStyleContext *context,
+ GtkCssValue *current,
GtkSymbolicColor *color)
{
g_return_val_if_fail (GTK_IS_STYLE_CONTEXT (context), FALSE);
+ g_return_val_if_fail (current != NULL, FALSE);
g_return_val_if_fail (color != NULL, FALSE);
return _gtk_symbolic_color_resolve_full (color,
+ current,
gtk_style_context_color_lookup_func,
context);
}
g_return_val_if_fail (result != NULL, FALSE);
val = _gtk_symbolic_color_resolve_full (color,
+ _gtk_style_context_peek_property (context, GTK_CSS_PROPERTY_COLOR),
gtk_style_context_color_lookup_func,
context);
if (val == NULL)
GtkSymbolicColor *color,
GdkRGBA *result);
GtkCssValue * _gtk_style_context_resolve_color_value (GtkStyleContext *context,
+ GtkCssValue *current,
GtkSymbolicColor *color);
void _gtk_style_context_get_cursor_color (GtkStyleContext *context,
GdkRGBA *primary_color,
GtkStyleProperties *props,
GdkRGBA *resolved_color)
{
- GtkCssValue *v;
+ GdkRGBA pink = { 1.0, 0.5, 0.5, 1.0 };
+ GtkCssValue *v, *current;
g_return_val_if_fail (color != NULL, FALSE);
g_return_val_if_fail (resolved_color != NULL, FALSE);
g_return_val_if_fail (props == NULL || GTK_IS_STYLE_PROPERTIES (props), FALSE);
+ current = _gtk_css_rgba_value_new_from_rgba (&pink);
v =_gtk_symbolic_color_resolve_full (color,
+ current,
resolve_lookup_color,
props);
+ _gtk_css_value_unref (current);
if (v == NULL)
return FALSE;
GtkCssValue *
_gtk_symbolic_color_resolve_full (GtkSymbolicColor *color,
+ GtkCssValue *current,
GtkSymbolicColorLookupFunc func,
gpointer data)
{
GtkCssValue *value;
g_return_val_if_fail (color != NULL, FALSE);
+ g_return_val_if_fail (current != NULL, FALSE);
g_return_val_if_fail (func != NULL, FALSE);
value = NULL;
if (!named_color)
return NULL;
- return _gtk_symbolic_color_resolve_full (named_color, func, data);
+ return _gtk_symbolic_color_resolve_full (named_color, current, func, data);
}
break;
GtkCssValue *val;
GdkRGBA shade;
- val = _gtk_symbolic_color_resolve_full (color->shade.color, func, data);
+ val = _gtk_symbolic_color_resolve_full (color->shade.color, current, func, data);
if (val == NULL)
return NULL;
GtkCssValue *val;
GdkRGBA alpha;
- val = _gtk_symbolic_color_resolve_full (color->alpha.color, func, data);
+ val = _gtk_symbolic_color_resolve_full (color->alpha.color, current, func, data);
if (val == NULL)
return NULL;
GtkCssValue *val;
GdkRGBA color1, color2, res;
- val = _gtk_symbolic_color_resolve_full (color->mix.color1, func, data);
+ val = _gtk_symbolic_color_resolve_full (color->mix.color1, current, func, data);
if (val == NULL)
return NULL;
color1 = *_gtk_css_rgba_value_get_rgba (val);
_gtk_css_value_unref (val);
- val = _gtk_symbolic_color_resolve_full (color->mix.color2, func, data);
+ val = _gtk_symbolic_color_resolve_full (color->mix.color2, current, func, data);
if (val == NULL)
return NULL;
color2 = *_gtk_css_rgba_value_get_rgba (val);
break;
case COLOR_TYPE_CURRENT_COLOR:
- return NULL;
+ if (current)
+ return _gtk_css_value_ref (current);
+ else
+ return NULL;
break;
default:
g_assert_not_reached ();
typedef GtkSymbolicColor * (* GtkSymbolicColorLookupFunc) (gpointer data, const char *name);
GtkCssValue * _gtk_symbolic_color_resolve_full (GtkSymbolicColor *color,
+ GtkCssValue *current,
GtkSymbolicColorLookupFunc func,
gpointer data);